Added new menu separator item. The drawing and size handling is still done
authorAlexander Larsson <alexl@redhat.com>
Wed, 21 Feb 2001 09:29:01 +0000 (09:29 +0000)
committerAlexander Larsson <alexl@src.gnome.org>
Wed, 21 Feb 2001 09:29:01 +0000 (09:29 +0000)
2001-02-21  Alexander Larsson  <alexl@redhat.com>

        * gtk/gtkseparatormenuitem.[ch]:
Added new menu separator item. The drawing and size handling
is still done in GtkMenuItem, but the API is a bit more sane.

* gtk/Makefile.am:
Add gtkseparatormenuitem.[ch].

* gtk/gtk.h:
Add gtkseparatormenuitem.h.

* gtk/gtkentry.c:
* gtk/gtkmenufactory.c:
* gtk/gtktextview.c:
Use the new API for menu separators.

* demos/gtk-demo/menus.c (create_menu):
Add some GtkSeparatorMenuItem demo code.

15 files changed:
ChangeLog
ChangeLog.pre-2-0
ChangeLog.pre-2-10
ChangeLog.pre-2-2
ChangeLog.pre-2-4
ChangeLog.pre-2-6
ChangeLog.pre-2-8
demos/gtk-demo/menus.c
gtk/Makefile.am
gtk/gtk.h
gtk/gtkentry.c
gtk/gtkmenufactory.c
gtk/gtkseparatormenuitem.c [new file with mode: 0644]
gtk/gtkseparatormenuitem.h [new file with mode: 0644]
gtk/gtktextview.c

index 63b783dd18595a68983fcc4f376c974b0ad993b9..ed636e5194b550596381d411de4109c202077421 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,23 @@
+2001-02-21  Alexander Larsson  <alexl@redhat.com>
+       
+        * gtk/gtkseparatormenuitem.[ch]:
+       Added new menu separator item. The drawing and size handling
+       is still done in GtkMenuItem, but the API is a bit more sane.
+       
+       * gtk/Makefile.am:
+       Add gtkseparatormenuitem.[ch].
+
+       * gtk/gtk.h:
+       Add gtkseparatormenuitem.h.
+       
+       * gtk/gtkentry.c:
+       * gtk/gtkmenufactory.c:
+       * gtk/gtktextview.c:
+       Use the new API for menu separators.
+       
+       * demos/gtk-demo/menus.c (create_menu):
+       Add some GtkSeparatorMenuItem demo code.
+
 2001-02-20  Havoc Pennington  <hp@redhat.com>
 
        * gtk/gtkaspectframe.c: Convert to new property API, patch from 
index 63b783dd18595a68983fcc4f376c974b0ad993b9..ed636e5194b550596381d411de4109c202077421 100644 (file)
@@ -1,3 +1,23 @@
+2001-02-21  Alexander Larsson  <alexl@redhat.com>
+       
+        * gtk/gtkseparatormenuitem.[ch]:
+       Added new menu separator item. The drawing and size handling
+       is still done in GtkMenuItem, but the API is a bit more sane.
+       
+       * gtk/Makefile.am:
+       Add gtkseparatormenuitem.[ch].
+
+       * gtk/gtk.h:
+       Add gtkseparatormenuitem.h.
+       
+       * gtk/gtkentry.c:
+       * gtk/gtkmenufactory.c:
+       * gtk/gtktextview.c:
+       Use the new API for menu separators.
+       
+       * demos/gtk-demo/menus.c (create_menu):
+       Add some GtkSeparatorMenuItem demo code.
+
 2001-02-20  Havoc Pennington  <hp@redhat.com>
 
        * gtk/gtkaspectframe.c: Convert to new property API, patch from 
index 63b783dd18595a68983fcc4f376c974b0ad993b9..ed636e5194b550596381d411de4109c202077421 100644 (file)
@@ -1,3 +1,23 @@
+2001-02-21  Alexander Larsson  <alexl@redhat.com>
+       
+        * gtk/gtkseparatormenuitem.[ch]:
+       Added new menu separator item. The drawing and size handling
+       is still done in GtkMenuItem, but the API is a bit more sane.
+       
+       * gtk/Makefile.am:
+       Add gtkseparatormenuitem.[ch].
+
+       * gtk/gtk.h:
+       Add gtkseparatormenuitem.h.
+       
+       * gtk/gtkentry.c:
+       * gtk/gtkmenufactory.c:
+       * gtk/gtktextview.c:
+       Use the new API for menu separators.
+       
+       * demos/gtk-demo/menus.c (create_menu):
+       Add some GtkSeparatorMenuItem demo code.
+
 2001-02-20  Havoc Pennington  <hp@redhat.com>
 
        * gtk/gtkaspectframe.c: Convert to new property API, patch from 
index 63b783dd18595a68983fcc4f376c974b0ad993b9..ed636e5194b550596381d411de4109c202077421 100644 (file)
@@ -1,3 +1,23 @@
+2001-02-21  Alexander Larsson  <alexl@redhat.com>
+       
+        * gtk/gtkseparatormenuitem.[ch]:
+       Added new menu separator item. The drawing and size handling
+       is still done in GtkMenuItem, but the API is a bit more sane.
+       
+       * gtk/Makefile.am:
+       Add gtkseparatormenuitem.[ch].
+
+       * gtk/gtk.h:
+       Add gtkseparatormenuitem.h.
+       
+       * gtk/gtkentry.c:
+       * gtk/gtkmenufactory.c:
+       * gtk/gtktextview.c:
+       Use the new API for menu separators.
+       
+       * demos/gtk-demo/menus.c (create_menu):
+       Add some GtkSeparatorMenuItem demo code.
+
 2001-02-20  Havoc Pennington  <hp@redhat.com>
 
        * gtk/gtkaspectframe.c: Convert to new property API, patch from 
index 63b783dd18595a68983fcc4f376c974b0ad993b9..ed636e5194b550596381d411de4109c202077421 100644 (file)
@@ -1,3 +1,23 @@
+2001-02-21  Alexander Larsson  <alexl@redhat.com>
+       
+        * gtk/gtkseparatormenuitem.[ch]:
+       Added new menu separator item. The drawing and size handling
+       is still done in GtkMenuItem, but the API is a bit more sane.
+       
+       * gtk/Makefile.am:
+       Add gtkseparatormenuitem.[ch].
+
+       * gtk/gtk.h:
+       Add gtkseparatormenuitem.h.
+       
+       * gtk/gtkentry.c:
+       * gtk/gtkmenufactory.c:
+       * gtk/gtktextview.c:
+       Use the new API for menu separators.
+       
+       * demos/gtk-demo/menus.c (create_menu):
+       Add some GtkSeparatorMenuItem demo code.
+
 2001-02-20  Havoc Pennington  <hp@redhat.com>
 
        * gtk/gtkaspectframe.c: Convert to new property API, patch from 
index 63b783dd18595a68983fcc4f376c974b0ad993b9..ed636e5194b550596381d411de4109c202077421 100644 (file)
@@ -1,3 +1,23 @@
+2001-02-21  Alexander Larsson  <alexl@redhat.com>
+       
+        * gtk/gtkseparatormenuitem.[ch]:
+       Added new menu separator item. The drawing and size handling
+       is still done in GtkMenuItem, but the API is a bit more sane.
+       
+       * gtk/Makefile.am:
+       Add gtkseparatormenuitem.[ch].
+
+       * gtk/gtk.h:
+       Add gtkseparatormenuitem.h.
+       
+       * gtk/gtkentry.c:
+       * gtk/gtkmenufactory.c:
+       * gtk/gtktextview.c:
+       Use the new API for menu separators.
+       
+       * demos/gtk-demo/menus.c (create_menu):
+       Add some GtkSeparatorMenuItem demo code.
+
 2001-02-20  Havoc Pennington  <hp@redhat.com>
 
        * gtk/gtkaspectframe.c: Convert to new property API, patch from 
index 63b783dd18595a68983fcc4f376c974b0ad993b9..ed636e5194b550596381d411de4109c202077421 100644 (file)
@@ -1,3 +1,23 @@
+2001-02-21  Alexander Larsson  <alexl@redhat.com>
+       
+        * gtk/gtkseparatormenuitem.[ch]:
+       Added new menu separator item. The drawing and size handling
+       is still done in GtkMenuItem, but the API is a bit more sane.
+       
+       * gtk/Makefile.am:
+       Add gtkseparatormenuitem.[ch].
+
+       * gtk/gtk.h:
+       Add gtkseparatormenuitem.h.
+       
+       * gtk/gtkentry.c:
+       * gtk/gtkmenufactory.c:
+       * gtk/gtktextview.c:
+       Use the new API for menu separators.
+       
+       * demos/gtk-demo/menus.c (create_menu):
+       Add some GtkSeparatorMenuItem demo code.
+
 2001-02-20  Havoc Pennington  <hp@redhat.com>
 
        * gtk/gtkaspectframe.c: Convert to new property API, patch from 
index 95ddb10e1a92284c6f2b325959a89e806e988154..ac8a7e2c5350a1997b72adfcbec90a2e18e17c0e 100644 (file)
@@ -118,7 +118,11 @@ do_menus (void)
       
       menu = create_menu (1, FALSE);
       gtk_menu_set_accel_group (GTK_MENU (menu), accel_group);
-
+      
+      menuitem = gtk_separator_menu_item_new ();
+      gtk_menu_shell_append (GTK_MENU_SHELL (menu), menuitem);
+      gtk_widget_show (menuitem);
+      
       menuitem = gtk_check_menu_item_new_with_label ("Accelerate Me");
       gtk_menu_shell_append (GTK_MENU_SHELL (menu), menuitem);
       gtk_widget_show (menuitem);
index 6c2f8b706cb7485ccefc200259620916f2cbf0e7..c330298af0a6e35f5ad74a4be4399dc8eb716f4b 100644 (file)
@@ -65,6 +65,7 @@ gtk_public_h_sources = @STRIP_BEGIN@ \
        gtkcalendar.h           \
        gtkcheckbutton.h        \
        gtkcheckmenuitem.h      \
+       gtkseparatormenuitem.h  \
        gtkclist.h              \
        gtkclipboard.h          \
        gtkcolorsel.h           \
@@ -228,6 +229,7 @@ gtk_c_sources = @STRIP_BEGIN@   \
        gtkcellrendererpixbuf.c \
        gtkcheckbutton.c        \
        gtkcheckmenuitem.c      \
+       gtkseparatormenuitem.c  \
        gtkclipboard.c          \
        gtkclist.c              \
        gtkcolorsel.c           \
index 19bbf630ac0e9bbd6511366ceb3135e3f3b473ca..f1676ca08419eec52c75e79e41cbdeb7b87522ca 100644 (file)
--- a/gtk/gtk.h
+++ b/gtk/gtk.h
 #include <gtk/gtkscrolledwindow.h>
 #include <gtk/gtkselection.h>
 #include <gtk/gtkseparator.h>
+#include <gtk/gtkseparatormenuitem.h>
 #include <gtk/gtksignal.h>
 #include <gtk/gtksocket.h>
 #include <gtk/gtkspinbutton.h>
index 75c486649cae9e23c2547d1deaa34829beb21846..21ca60f93b7ba7683cc7bc87ce36bba89bbadb5f 100644 (file)
@@ -38,6 +38,7 @@
 #include "gtkmain.h"
 #include "gtkmenu.h"
 #include "gtkmenuitem.h"
+#include "gtkseparatormenuitem.h"
 #include "gtkselection.h"
 #include "gtksignal.h"
 
@@ -2737,7 +2738,7 @@ gtk_entry_popup_menu (GtkEntry       *entry,
       append_action_signal (entry, entry->popup_menu, _("Copy"), "copy_clipboard");
       append_action_signal (entry, entry->popup_menu, _("Paste"), "paste_clipboard");
 
-      menuitem = gtk_menu_item_new (); /* Separator */
+      menuitem = gtk_separator_menu_item_new ();
       gtk_widget_show (menuitem);
       gtk_menu_shell_append (GTK_MENU_SHELL (entry->popup_menu), menuitem);
 
index 4426ffff6e96eef8c2102e2f776626009ca90e6d..08a4324716fe311d9453667db2d066e4d011d516 100644 (file)
@@ -30,6 +30,7 @@
 #include "gtkmenubar.h"
 #include "gtkmenufactory.h"
 #include "gtkmenuitem.h"
+#include "gtkseparatormenuitem.h"
 #include "gtksignal.h"
 
 
@@ -244,7 +245,7 @@ gtk_menu_factory_create (GtkMenuFactory *factory,
        */
       if (strcmp (path, "<separator>") == 0)
        {
-         entry->widget = gtk_menu_item_new ();
+         entry->widget = gtk_separator_menu_item_new ();
          gtk_container_add (GTK_CONTAINER (parent), entry->widget);
          gtk_widget_show (entry->widget);
        }
diff --git a/gtk/gtkseparatormenuitem.c b/gtk/gtkseparatormenuitem.c
new file mode 100644 (file)
index 0000000..43437c4
--- /dev/null
@@ -0,0 +1,69 @@
+/* GTK - The GIMP Toolkit
+ * Copyright (C) 1995-1997 Peter Mattis, Spencer Kimball and Josh MacDonald
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the
+ * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+ * Boston, MA 02111-1307, USA.
+ */
+
+/*
+ * Modified by the GTK+ Team and others 1997-2000.  See the AUTHORS
+ * file for a list of people on the GTK+ Team.  See the ChangeLog
+ * files for a list of changes.  These files are distributed with
+ * GTK+ at ftp://ftp.gtk.org/pub/gtk/. 
+ */
+
+#include "gtkseparatormenuitem.h"
+
+static void gtk_separator_menu_item_class_init (GtkSeparatorMenuItemClass *klass);
+
+static GtkMenuItemClass *parent_class;
+
+GtkType
+gtk_separator_menu_item_get_type (void)
+{
+  static GtkType separator_menu_item_type = 0;
+
+  if (!separator_menu_item_type)
+    {
+      static const GTypeInfo separator_menu_item_info =
+      {
+       sizeof (GtkMenuItemClass),
+       NULL,           /* base_init */
+       NULL,           /* base_finalize */
+       (GClassInitFunc) gtk_separator_menu_item_class_init,
+       NULL,           /* class_finalize */
+       NULL,           /* class_data */
+       sizeof (GtkMenuItem),
+       16,             /* n_preallocs */
+       (GInstanceInitFunc) NULL,
+      };
+
+      separator_menu_item_type = g_type_register_static (GTK_TYPE_MENU_ITEM, "GtkSeparatorMenuItem", &separator_menu_item_info, 0);
+    }
+
+  return separator_menu_item_type;
+}
+
+static void
+gtk_separator_menu_item_class_init (GtkSeparatorMenuItemClass *klass)
+{
+  parent_class = gtk_type_class (gtk_menu_item_get_type ());
+}
+
+GtkWidget*
+gtk_separator_menu_item_new (void)
+{
+  return GTK_WIDGET (gtk_type_new (gtk_separator_menu_item_get_type ()));
+}
diff --git a/gtk/gtkseparatormenuitem.h b/gtk/gtkseparatormenuitem.h
new file mode 100644 (file)
index 0000000..fbac001
--- /dev/null
@@ -0,0 +1,70 @@
+/* GTK - The GIMP Toolkit
+ * Copyright (C) 1995-1997 Peter Mattis, Spencer Kimball and Josh MacDonald
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.         See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the
+ * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+ * Boston, MA 02111-1307, USA.
+ */
+
+/*
+ * Modified by the GTK+ Team and others 1997-2000.  See the AUTHORS
+ * file for a list of people on the GTK+ Team.  See the ChangeLog
+ * files for a list of changes.  These files are distributed with
+ * GTK+ at ftp://ftp.gtk.org/pub/gtk/. 
+ */
+
+#ifndef __GTK_SEPARATOR_MENU_ITEM_H__
+#define __GTK_SEPARATOR_MENU_ITEM_H__
+
+#include <gdk/gdk.h>
+#include <gtk/gtkmenuitem.h>
+
+
+#ifdef __cplusplus
+extern "C" {
+#endif /* __cplusplus */
+
+
+#define GTK_TYPE_SEPARATOR_MENU_ITEM            (gtk_separator_menu_item_get_type ())
+#define GTK_SEPARATOR_MENU_ITEM(obj)            (GTK_SEPARATOR_CAST ((obj), GTK_TYPE_SEPARATOR_MENU_ITEM, GtkSeparatorMenuItem))
+#define GTK_SEPARATOR_MENU_ITEM_CLASS(klass)    (GTK_SEPARATOR_CLASS_CAST ((klass), GTK_TYPE_SEPARATOR_MENU_ITEM, GtkSeparatorMenuItemClass))
+#define GTK_IS_SEPARATOR_MENU_ITEM(obj)         (GTK_SEPARATOR_TYPE ((obj), GTK_TYPE_SEPARATOR_MENU_ITEM))
+#define GTK_IS_SEPARATOR_MENU_ITEM_CLASS(klass) (GTK_SEPARATOR_CLASS_TYPE ((klass), GTK_TYPE_SEPARATOR_MENU_ITEM))
+#define GTK_SEPARATOR_MENU_ITEM_GET_CLASS(obj)  (GTK_SEPARATOR_GET_CLASS ((obj), GTK_TYPE_SEPARATOR_MENU_ITEM, GtkSeparatorMenuItemClass))
+
+
+typedef struct _GtkSeparatorMenuItem       GtkSeparatorMenuItem;
+typedef struct _GtkSeparatorMenuItemClass  GtkSeparatorMenuItemClass;
+
+struct _GtkSeparatorMenuItem
+{
+  GtkMenuItem menu_item;
+};
+
+struct _GtkSeparatorMenuItemClass
+{
+  GtkMenuItemClass parent_class;
+};
+
+
+GtkType           gtk_separator_menu_item_get_type        (void) G_GNUC_CONST;
+GtkWidget* gtk_separator_menu_item_new            (void);
+
+
+#ifdef __cplusplus
+}
+#endif /* __cplusplus */
+
+
+#endif /* __GTK_SEPARATOR_MENU_ITEM_H__ */
index 283a72e8b9ea4049bd4e48b52c59178d6d63bbc3..a4537d6743d843fb095977959a2279513a866f3d 100644 (file)
@@ -32,6 +32,7 @@
 #include "gtkmain.h"
 #include "gtkmenu.h"
 #include "gtkmenuitem.h"
+#include "gtkseparatormenuitem.h"
 #include "gtksignal.h"
 #include "gtktextdisplay.h"
 #include "gtktextview.h"
@@ -4905,7 +4906,7 @@ gtk_text_view_popup_menu (GtkTextView    *text_view,
       append_action_signal (text_view, text_view->popup_menu, _("Copy"), "copy_clipboard");
       append_action_signal (text_view, text_view->popup_menu, _("Paste"), "paste_clipboard");
 
-      menuitem = gtk_menu_item_new (); /* Separator */
+      menuitem = gtk_separator_menu_item_new ();
       gtk_widget_show (menuitem);
       gtk_menu_shell_append (GTK_MENU_SHELL (text_view->popup_menu), menuitem);